package com.smh;

import org.junit.jupiter.api.Test;

/**
 * @author shiminghui
 * @date 2025/3/18 15:01
 * @description: TODO
 */
public class _064_打家劫舍 {


    @Test
    public void test1() {
        System.out.println(rob(new int[]{2, 1, 1, 1}));
    }

    /**
     * 你是一个专业的小偷，计划偷窃沿街的房屋。每间房内都藏有一定的现金，影响你偷窃的唯一制约因素就是相邻的房屋装有相互连通的防盗系统，
     * 如果两间相邻的房屋在同一晚上被小偷闯入，系统会自动报警。
     * 给定一个代表每个房屋存放金额的非负整数数组，计算你 不触动警报装置的情况下 ，一夜之内能够偷窃到的最高金额。
     * <p>
     * 2   5   7   9   1
     * 2    2   0   0   0   0
     * 5    2   5   0   0   0
     * 7    2   5   9   0   0
     * 9    2   5   9   14  0
     * 1    2   5   9   14  14
     */
    public int rob(int[] nums) {
        if (nums.length == 1) {
            return nums[0];
        }
        if (nums.length == 2) {
            return Math.max(nums[0], nums[1]);
        }
        int[] dp = new int[2];
        dp[0] = nums[0];
        dp[1] = Math.max(nums[0], nums[1]);
        for (int i = 2; i < nums.length; i++) {
            if (nums[i] + dp[0] > dp[1]) {
                int temp = dp[0];
                dp[0] = dp[1];
                dp[1] = nums[i] + temp;
            } else {
                dp[0] = dp[1];
            }
        }
        return dp[1];
    }
}
